\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_

**Optimized KNN Implementation on an FGPA Cluster**

\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_

Project Proposal

Andrew Farran

Grant Fettig

Daniel McKee

Western Michigan University

ECE 4810

12/08/2017

[**Project Overview**](#_dj4dk6whsvl3) **2**

[Background and Description](#_o100kb4qwxj0) 2

[Need Statement](#_8741jf79a01w) 2

[**Project Specifications**](#_37zy72vbs5iq) **3**

[Physical Characteristics](#_r0viyp9jbl2v) 3

[Functionality](#_apf4twjfatph) 3

[Constraints](#_88j7bix7z1tx) 4

[Economic](#_tcjwyssk57r9) 4

[Health and Safety](#_h4zecmt5g255) 4

[Environmental and Sustainability](#_v9no6qmagcfn) 5

[Ethical](#_37ipe3u4ha1k) 5

[Social](#_mx82tb721iel) 5

[Manufacturability](#_ql1ze5orjzkr) 6

[Physical](#_nujl8a2kzf35) 6

[Economic](#_lb7e07iv5wy0) 6

[Resources](#_jcv68auvuor) 7

[**Design**](#_deotuivkkth4) **7**

[Literature Search](#_vbxd1hc77zdx) 7

[Concept](#_4rmx0jiovj19) 10

[Figure 1: Block Diagram of the FPGA Cluster Hardware Accelerator. The master Zybo Board will communicate to the slave Nexys 4 FPGA boards via Ethernet.](#_os5jyzrfom9n) 10

[Alternative Approaches](#_b3bb0edjjf2m) 11

[Precedence Matrix](#_n8u68845udti) 11

[The precedence matrix shown in figure 2 helps organize the different components of the entire system. By highlighting the dependencies among these components, the ideal sequence to complete each section of the project is determined.](#_1nqwsivxcqlg) 12

[Hardware Components](#_tu56oq5orcis) 12

[Software Components](#_l1qfsi2tff4a) 12

[Models and Simulations and Design Validation](#_uclrxysg9ej) 13

[Testing Procedures](#_1q5vsvq1w4q7) 13

[**Plan of Work**](#_hj27pnbukr3e) **15**

[Work Flow Diagram](#_bh1y15lk4915) 15

[Critical Path Network](#_c4rqlijpsbr4) 16

[CPN Key](#_r6kohcdostbt) 17

[**Project Deliverables**](#_788cesmgsmxt) **19**

[**Conclusions**](#_zi3xzunc3gn3) **19**

[**References**](#_yclw1rqh2lnn) **20**

# Project Overview

## Background and Description

This project is a continuation of the Hardware Accelerator created by WMU student’s Martin Cowley and Alan Irwin in 2016. A hardware accelerator uses custom hardware to solve a problem faster and more efficiently than it can be solved in software. This hardware accelerator has been developed to optimize the k-nearest neighbor machine learning algorithm. Cowley and Irwin’s project utilized a single development board with an ARM processor and a field programmable gate array (FPGA) to perform arithmetic and data operations. Martin Cowley has thus continued his work by creating a pipelined design for the FPGA logic. It is the goal of this team to build and utilize a FPGA cluster to further increase the performance of Cowley and Irwin’s Hardware Accelerator. Additionally, the FPGA cluster shall be a prototype that can be further used to accelerate multiple different algorithms in the future.

## Need Statement

Developing a Master-Slave parallel FPGA cluster design will improve upon execution time, and performance for various machine learning algorithms. This design optimization will allow more data to be analyzed in a shorter amount of time, providing more accurate predictions in weather, health, and image processing applications.

# Project Specifications

## Physical Characteristics

The physical components of the FPGA Cluster are a Zybo Z7-10 development board, three ethernet cables, an ethernet switch, and two Nexys 4 trainer boards. A PC and a USB cable will also be needed but these are external to the main focus of the project. The Zybo board has many hardware components. The hardware components being utilized in the cluster are an ARM processor, 1GB of DDR3 onboard memory, 10/100/1000 ethernet PHY, and a FPGA. The processor is a 650 MHz dual-core ARM Cortex-A9. The FPGA is equivalent to the Artix-7 FPGA with 17,600 look-up tables, 32,200 flip-flops, and 270KB of block RAM. The hardware components being used on the Nexys 4s are the Artix-7 FPGA and 10/100 ethernet PHY.

## Functionality

Before the FPGA cluster can perform its operations, the data set must be transmitted from the PC to the onboard memory of the master Zybo board via UART. After the data has all been downloaded the FPGAcluster can perform its operations. The overall task for this FPGA cluster is to obtain the kth nearest neighbors of the data set and to store these into the DRAM of the Zybo board. The first step is one core of the processor directs data to the Zybo FPGA and the two slave FPGAs. The FPGAs then find the distances between the vectors and then wait for the other processor core to ask for the data. This processor core then receives the vector distance and decides if the vector distance should be stored into the kth nearest or discarded. If the vector should be stored then the processor stores it and then sorts the kth nearest array.

## Constraints

The constraints of this project center around hardware availability and the cost of FPGA boards as well as the bit-rate of data transfer through a communication BUS. An ideal FPGA board for our design would be one with a large amount of on-board storage, but because of the higher costs of FPGA boards it may not be a financially viable option. Finding the balance between economic realizability and level of optimization needs to be considered.

## Economic

FPGA’s used to be very expensive, but as time goes on the price has dropped significantly. Using an FPGA cluster may soon be the most economical choice for running complex algorithms. Companies such as amazon have cloud based services where a user can download their hardware description language(HDL) and run their programs on an FPGA cluster. Graphical Processing Units (GPUs) are generally cheaper than FPGAs so that could be an approach to solving this problem but when considering power consumption and speedup the FPGA is more practical for the given problem [1].

## Health and Safety

Any person with general knowledge of electronic devices can use this product without harming their health. All electrical components are using standard DC voltages. A plastic case will be built around the various components mainly to protect the hardware but this will also avoid electrical shock.

## Environmental and Sustainability

To achieve the speed required to compute the kth nearest algorithm, a FPGA or GPU must be used. Researchers have programmed the k-nearest neighbors algorithm with OpenCL on GPUs and in Verilog on a FPGA and tested them against each other [2]. The algorithm on a FPGA has shown a decrease in energy consumption while the use of GPUs with this algorithm has shown the opposite despite achieving the same goal [2].

## Ethical

Advances in computing improves nearly all technology industries. Some examples are: better cancer-screening devices, more accurate systems targeted for missiles, or improved personal electronic devices. These can be used to save lives, take lives, share information, and intrude on people’s privacy. The ethical stance of using high performance computing is all in the way the user intends on applying the technology.

## Social

The types of technology that will utilize the design that the project focuses on will not be purchased by an average consumer at an electronics store. The machine learning and parallel architecture will be utilized to make predictions regarding things such as weather, and image processing for x-rays and MRIs in the medical field [3]. Thus, the social impact will be that people will benefit from the advancement of these optimizations in a secondary capacity by watching the weather or going to the doctor.

## Manufacturability

The FPGA cluster has a high manufacturability. The hardware can be purchased and the software can be easily downloaded to the different components. If the product was to be mass produced it would be cheaper to replicate the FPGA functionality with an integrated circuit as there are companies that take FPGA designs and turn them into integrated circuits. The processor could be purchased separately in the case of this design.

**Project Feasibility**

## Physical

As this is a continuation of a project from previous semesters, the design of the board connection layout as well as the software portion are physically realizable. On top of the existing design, there are numerous journal articles that have shown the physical design the group will work with is feasible. A pipelined architecture allows for the optimization of throughput as well as latency [4]. The combination of the pipelined architecture in addition to a parallelized design of the communication has shown they are both realizable as well as more efficient [5].

## Economic

This project does not require any manufacturing from the group and does not require a design to be sent to a third party for manufacturing. Everything that will be used to meet the specification requirements for this projected can be purchased. This will include the Zybo boards, the Nexys boards and well as any communication BUS that is to be decided at a later time. While these boards are not as cheap as many microcontrollers, with the Zybo boards costing around $200 each and the Nexys boards costing around $350 each, they are on the lower end of the spectrum for FPGA boards pricing. The minimum price that is expected for this project is $850 with a majority of the cost coming from the cost of FPGA boards.

## Resources

Aside from potential guidance from our project sponsor, the project is also being worked on by Martin Cowley. His current focus is the continuation of the hardware coding while the focus for the group will be to create optimized communication between the FPGA boards to fully utilize the partitioned parts of the algorithm that is spread throughout the cluster.

# **Design**

## Literature Search

The use of an FPGA along with a microcontroller allows the hardware programming design to be tailored to the application requirements [6]. Great need has been expressed for acceleration of hardware. With no locality of data, a parallel software implementation alone is not very efficient. To utilize the pipelined design of this architecture, it is important to have the data stored in a single, localized space [7]. L.W. Kim et al. have described their usage of pipelining and parallelization of hardware in the context of Artificial Neural Networks. While their algorithm will not be used by the group for this project, the concept of minimizing the complexity of data flow is essential [7].

Kilts uses Henry Ford’s assembly line to represent the idea of a pipeline [4]. As the data goes through the various hardware stages, other data begins to follow once a certain stage is reached, just like cars on an assembly line. On top of a pipelined design, Kilts discusses the essential design requirements to maximize hardware speed [4]. Included in this are: designing the hardware for high-throughput, ensuring low latency, and providing layers to separate combinational logic amongst other things [4]. Much of this can be accomplished with hardware designers adjusting the numerical precision, number of stages in a pipeline, as well as the number of cores that these processes are running on [6].

A popular learning algorithm that is instance-based is the kth-nearest neighbor [8]. This machine learning algorithm must identify and place the nearest neighbors into a query, then determine the distance to the next nearest neighbor with *k* amounts of data points [8]. Data points of this algorithm are often represented in terms of a dissimilarity function [11]. A function with larger values represent further distances from the main data point [9]. In order to determine the category of a desired element, the algorithm must take in a parameter from the result of a distance calculation [10]. This parameter is the distance between *k* data points and the main point [10]. That new point belongs to the category that it shares the closest distances with [10]. For example, while fruits are generally defined as tasting sweet, a sweet potato is categorized as a vegetable [10]. Despite its sweetness, it is closer in distance to more data points of the vegetable category such as green beans, lettuce and various types of potatoes [10].

In a more hardware driven sense, researchers have implemented FPGA clusters, which showed significant speed-up over software-only solutions. One implementation of a k-means algorithm on a FPGA cluster resulted in a speed-up range from 15.5 to 20.6 [11]. The conclusion was that using multiple FPGAs can help relieve the I/O communication overhead which resulted in higher performance [11]. This information has provided the group with an estimate on how much of a speedup can be expected from the kth nearest software algorithm with a FPGA cluster. To show a definite speed up, however, we must know the performance of the current design from previous semester groups.

Another way of parallelizing algorithms or applications is with the use of GPUs. Researchers programmed the *k*-nearest neighbors algorithm with OpenCL on GPUs and in Verilog on a FPGA [2]. Both of these systems were seen to improve speed of the execution [8]. The algorithm on a FPGA has shown a decrease in energy consumption while the use of GPUs with this algorithm has shown the opposite despite achieving the same speedup [8]. The GPU implementation is also slower because multiple kernels are executed sequentially but must share a global memory [2]. The only downside of the FPGA implementation that was mentioned in this paper is the amount of time to create these complex systems with a hardware description language [2].

A similar design to what we will be attempting to develop has been created by other researchers: to have a cluster of FPGAs representing parallel cell units that utilizes a main controller board for high-level control tasks and accessing main memory [12]. Ratsaby and Zavielov [13] have provided an implementation that has shown the need for a hardware-software combination. With the data compressed to a realizable size, the arithmetic computations and nearest neighbor estimates can be done easily on a single FPGA chip [13]. The speed-up is significant compared to a software-only implementation. These represent the general idea to which our group will work towards in an attempt to meet the project specifications.

## Concept

The majority of the software developed for this project will be created, simulated, and programmed with Xilinx Vivado IDE and Xilinx SDK. Additional contributions include continued pipeline work that is being done by Martin Cowley as well as the guidance of Dr. Lina Sawalha. Below is the block diagram of our design. It shows general flow of logic through the cluster. The lines provide a visualization for directional flow of communication from device to device.![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAr0AAAF3CAYAAACov/OXAABBcUlEQVR42u2dC5gU1Z232zAwIwww3C+CGXWyEm4iqIiXKMoKES9EjBIvET90IaJ4XxQVQSWiouLdEGRZVIKKgU8J+uGFqEFEJV5wgyuuowsJGjTgNyYY0dT2r5zTe7qmqrp6pmemq/t9n+f3wHRXV1dXT3e/c/p//ieRAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIAI9EpmYteuXe/ec889V3Tv3n1Dx44dt3bo0GE7IaRp0r59+8/atWv3cfJ1+Ery9Tcv+Zo8K5lK3p4AAAAaRlV5efnMbt26bWrbtu2XZ5999lezZ892Fi5c6KxevdrZuHGjU1NT4wBA47N9+3anurra2bRpk7NixQpn7ty5zrhx42q6dOlS06ZNm09KS0tvSb5mB/G2BQAAEJ1BnTt3fiP5YbpzypQpuyS4u3btwjoA8hT9AXrllVf+vVOnTp8nBfiV5Gt4JG9jAAAAISO7Sdn9vx06dNg5f/58RBcgZug1+6tf/err7373u5+Wlpb+Lvma7s/bGgAAgEX79u2nVVRU/O3aa6/9ZufOndgDQMzl9+677/5r69atdyRf3tcmU8K7HAAAFDtlHTp0WDZgwIC/bd68GVsAKCC2bt3qHHDAAX8qKSl5Ofla787bHQAAFCvdKyoq3jnllFP+xuguQOFyxRVXfNyyZctNydd8H972AACg6IS3devWn15//fXfoAQAhc9dd931SYsWLf6UfO1X8fYHAADFQnnbtm3/MGvWrL+jAgDFw6233rq1pKTkveR7QGfeBgEAoPCNt7x82WmnnfY3FACg+Dj77LM/3G233VbwTggAAAVNWVnZtQMHDqyhHRlAcaLXfs+ePbcmvl3NDQAAoCDp07Zt2xrN6AaA4uXVV1/9urS09BP9HczbIgAAFBytW7deNWfOHMoaAMA56aST/px8W7iKd0YAACg0juzSpct2yhoAQGjp4rKysr8kWLgCAAAKid133/1tLU/KRz0AGIYOHVqTfHsYzTskAAAUCof17NlzGx/xAGAzf/58TWpbla9vXF26dn6/a7cuO0l806lzx2f4CG44nTq039ijW+edhDRFDtq//3txfr3cPm3atE/5iAcAG01qLS8v35mvb1ztK9pt/88/b3BIfFNWVrYVZW04bcvbbPv6j+sdQpoiEt/YvlhatWq1RfV7AABevv/973+dfJsYhPQSpBfpJSTu0juoY8eOjPICgC/jx493DjnkkBlIL0F6kV5C4i691/7sZz/7gI92APBj7ty5zvDhw3+L9BKkF+klJO7S++D8+fP/zEc7APixfPly58ADD/wvpJcgvUgvIXGX3tXPP/88rcoAwJe1a9c6/fv334H0EqQX6SUk1tLbokWLDzZt2sQnOwD4Ul1d7fTq1esrpJcgvUgvIbGW3u985zt/ramp4ZMdAMKkdxfSS5BepJeQWEtvSUkJxgsAgWzfvh3pJUgv0ktI/KV3991338rHOgCEgfQSpBfpJQTpBQCkF+klSC/SS5BepBcAkF6klyC9SC9BepFeAEB6kV6kF5BegvQivQCA9CK9SC8gvQTpRXoBAOklSC/Si5ARpBfpBQCklyC9SC8hSC8AANJLkF6k1yfTL53oJO/CTWXvns6O916KfNsFc2embqv9IIyNk083/tZ9bnSezzrleKQX6QUApJcgvUhvQ6RXmXz2qUhvnuXUE0emzjPSi/QCANJLkF6kNwfSqzy3dB7SmydZfN+Nac8N0ov0AgDSS5BepDdH0hu1zAHpbdx8+PpKp6JdW6QX6QUApJcgvUhvY0hv1DIHpLdxc8SwIe657dyxAulFegEA6SVIL9KbK+mdeObJTklJi8hlDkhv4+Xm6Re751XPh13igPQivQCA9BKkF+ltoPRKYi+ddGbkModspFcCffrYY51ePbqlbqP/67I1Ty70vc37rzzpSp7JOy88Hrj/lQ/fndpOj+HLj151ZdFcpusznQt7H+tWPph23btrljsXnnua06/PPqk/DMrbtHb267evc9WF5zhb3liVs+dk/arFqfvQvnUekF6kFwCQXoL0Ir05lN4vPljr9KmqjFTmEEV6Jc0SW78SCjsaZZaohnUuGDp4gO82qn21SwCeWHRHSrTNZSoViFpOUFbayvl4w3Opyx+dd3PaCLhfdBtt19DnQ+dfYq19Sqj1eJFepBcAkF6C9CK9OZZeXaaR1yhlDpmkV8I2cvghqW00KUujsL9ecKsbjWLasio59utRa48O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)

## Figure 1: Block Diagram of the FPGA Cluster Hardware Accelerator. The master Zybo Board will communicate to the slave Nexys 4 FPGA boards via Ethernet.

## Alternative Approaches

The design approach discussed will most likely not be the final design. There are many alternative approaches to creating an FPGA cluster to solve the kth nearest algorithm. Having more or less slave FPGAs could result in a better speedup or make designing the cluster simpler. Deciding how many CPU cores are going to be used, what the cores will be doing, and how the processor will complete the task needed are all different approaches for designing the software in the cluster.

An alternative approach to speeding up the kth nearest algorithm would be to use GPUs rather than FPGAs. However, this is not the focus of the project and the materials needed for this approach are not accessible. Studies have also shown that FPGAs can perform similar speedup with less power consumption[8].

## Precedence Matrix

**Figure 2: Precedence Matrix. Insures the completion of the hardware accelerator.**

## The precedence matrix shown in figure 2 helps organize the different components of the entire system. By highlighting the dependencies among these components, the ideal sequence to complete each section of the project is determined.

## Hardware Components

Below are the components that are to be used to complete the design as specified. These will be used in tandem with the software components to create one cohesive cluster. The hardware is to be optimized so that the software and hardware together handle data in the most efficient way possible.

|  |  |  |
| --- | --- | --- |
| **Hardware Components** | **Quantity** | **Description** |
| Nexys 4 | 2 | Artix-7 FPGA, 10/100 Ethernet PYE |
| Zybo Z7 | 1 | Artix-7 FPGA, 10/100/1000 Ethernet PHY, 1GB DDR3 Onboard Memory |
| Ethernet Switch | 1 | 100MB capability, At least 4 ports |
| Ethernet Cable | 3 | At least 1ft, Cat6 |
| Power Cable | 4 | AC to DC power supplies (5VDC at 2.5A) |
| Plastic Case | 1 | Encapsulates Hardware Components |

**Table 1: Hardware To Be Used**

## 

## Software Components

Below are the software components that will be implemented on some of the hardware listed above, most namely the Nexys 4 and Zybo Z7. As described above, in order to have a FPGA cluster that is as efficient as possible, the hardware and software need to work together in a cohesive manner.

|  |  |  |
| --- | --- | --- |
| **Software Components** | **Location** | **Description** |
| Data Sorting Algorithm | Zybo Z7-10 | Bubble Sort Algorithm Implemented In C |
| Euclidean Distance Calculator | Zybo Z7-10, Nexys 4s | Vector Distance Finding Algorithm Implemented in Verilog |
| Data Streaming Unit | Zybo Z7-10 | Controls Data Flow Between DRAM, Processors, and FPGAs. Implemented In C. |
| Execution Time Unit | Zybo Z7-10 | Measures The Time Between The Start And Finish Of The Kth Nearest Neighbor Algorithm. Implemented In C. |
| Xilinx Power Estimator | Main Computer | Determine power and cooling specifications to avoid overdesign or under-design of the cluster |
| Xilinx Vivado SDK - ZYNQ | Main Computer | Software Development Kit |

**Table 2: Software To Be Used**

## Models and Simulations and Design Validation

Simulations that we will perform for this project will focus mostly around the timing simulations using Xilinx Vivado. This will provide timing diagrams along with other data that will provide the speed-up of the new design over the previous design. We will also use Xilinx Power Estimator (XPE) for determining the power necessary for an efficient design.

## Testing Procedures

Some things, like the power cables and ethernet cables, need to be tested first to ensure proper functionality. From there as progress continues on the project, more hardware and software elements will be tested for functionality as well as efficiency. Below shows the components that are to be tested to ensure the FPGA cluster functions as specified.

|  |  |
| --- | --- |
| **Component** | **Testing Procedure** |
| Nexys 4s | Implement Simple Verilog Code and Confirm Correct Results |
| Zybo Z7 | Run Cowley and Irwin’s Hardware Accelerator and Confirm Correct Results |
| Ethernet Switch & Ethernet Cables | Test with a known working laptop and network |
| Power Cables | Test with a known working device |
| Data Sorting Algorithm | Input a test data set with known results and see if the results of our algorithm are correct |
| Euclidean Distance Calculator | Input a test data set with known results and see if the results of our algorithm are correct |
| Data Streaming Unit | Input a test data set to the processor and see if the FPGA receives the correct values |
| Execution Time Unit | Use this implementation on Cowley and Irwin’s accelerator |

**Table 3: Hardware Testing Table. This lists the components that will need to be tested throughout the project to determine if the design is functioning as specified.**

# Plan of Work

## Work Flow Diagram

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAADUlEQVR42mP4//8fAwAI+gL9Kv2mJAAAAABJRU5ErkJggg==)

**Figure 3: Workflow Diagram. The order of steps that must be completed in order to complete the hardware accelerator.**

## 

The workflow diagram above is a visual showing the work progess that has been completed to date. For a more representative visual of what the flow of events will look like for the remainder of the project, our Critical Path Network (CPN) should be referenced. This can be seen on the following page. It provides specific events along with the time it will take to complete each individual task.

## Critical Path Network

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAADUlEQVR42mP4//8/AwAI/AL+eMSysAAAAABJRU5ErkJggg==)

**Figure 4: Critical Path Network (CPN). Provides a time table for next semester’s events to be completed.**

The durations and times shown in the above CPN exclude most weekends between the start and end date shown. There are 110 days to complete the project in the given times, 80 of which are weekdays.

The earliest event time for each event is found by adding a preceding event’s early time with the duration to arrive at the selected event. This is done for all preceding events, and the largest value is taken. The starting event has event time 0.

E.g. event G. Its predecessors have early times of 2 and 1. Both have a duration to G of 4.5. The early time for G is 6.5 (2 + 4.5) because it is the larger sum of a preceding time and duration.

The latest event time for each event is found by subtracting the duration to arrive at a following event from that event’s late time. This is done for all following events, and the smallest value is taken. The final event has the same early and late event time.

E.g. event B. The following events have late times of 11 and 5 with durations 4.5 and 2, respectively. The late time for B is 3 (5 - 2) because it is the smaller difference of a following time and duration.

The independent float for each event is its latest minus earliest event time. An example of this is shown in the CPN Key.

## CPN Key

|  |
| --- |
| 1. Starting point 2. Installation of Xilinx Vivado and SDK is complete 3. Acquired hardware accelerator code from previous design project 4. Acquired ZYBO and Nexys 4 boards 5. Acquired ethernet switch 6. Acquired ethernet cables and power supplies 7. Made any necessary adjustments to baseline code 8. Verified operation of baseline code 9. Created / acquired dataset of training and test vectors 10. Added logic / instructions to measure system performance 11. Benchmarked baseline hardware accelerator on physical board 12. Found MAC addresses of each board in cluster 13. Tested data transfer between boards via ethernet switch 14. Created program to test data transfer across cluster 15. Added logic for bus communication signals 16. Added instructions to manage multiple FPGA blocks 17. Verified data transfer between boards 18. Updated instructions to efficiently stream data to each FPGA 19. Changed logic parameters depending on streaming data size and order 20. Tested system to verify data streaming from memory to FPGAs 21. Tested system to verify distance calculations in FPGAs are returned to the processor 22. Tested system to verify all distances are accounted for and the k nearest are selected 23. Updated FPGA logic to pipelined design (developed by Martin Cowley) 24. Final verification of system accuracy is complete 25. Benchmarked FPGA cluster performance 26. Compiled results and conclusions 27. Captured pictures of system operation 28. Rough draft of final project report is complete 29. Creation of graphs and drawings is complete 30. Proofreading of report is complete 31. Adjustments to final project report are complete and report delivered |

# Project Deliverables

Deliverables for this project should include results of tests run to determine the speedup and power consumption of the group’s optimized design, as well a working FPGA cluster. The boards will be held in one or more cases and the test results will be presented in report and presentation format with figures showing timing diagrams in addition to well commented verilog (.v) and (.c) files.

# Conclusions

As this project is a continuation of previous semester senior design students, most of the hardware programming has already been completed. The pipelined architecture is still being worked on, so the work to be done by our group is mainly focused towards the optimization of the current architecture and design. While there are only a few main areas of focus for this optimization, there are many different things that can be done for each. The two methods to be used for optimization are the parallelism of the instructions in hardware and the type of communication BUS. Parallelization of hardware will allow more instructions to be executed in a shorter amount of time. This is important as the more data points the machine learning algorithm has to work with, the more precise the results. The decision of where to store the data and how it is fetched will contribute to the speed of the processes. This step is hindered by the bitrate of a communication BUS. Serial communication will not be as efficient as data can only be transmitted one direction so a parallel BUS, which will allow data to flow in opposite directions simultaneously, is the best option.

# References

[1]“GPU vs FPGA Performance Comparison”, Berten Digital Signal Processing, 2016

[2]F. Muslim, A. Demian, L. Ma, L. Lavagno and A. Qamar, "Energy-efficient FPGA Implementation of the k-Nearest Neighbors Algorithm Using OpenCL", *Position Papers of the 2016 Federated Conference on Computer Science and Information Systems*, 2016.

[3]J. Bresnick, "Top 4 Machine Learning Use Cases for Healthcare Providers", *HealthITAnalytics*, 2017. [Online]. Available: https://healthitanalytics.com/news/top-4-machine-learning-use-cases-for-healthcare-providers. [Accessed: 10- Oct- 2017].

[4]S. Kilts, *Advanced FPGA design*. Hoboken, NJ: Wiley, 2007, pp. 1-16.

[5]L. Kim, S. Asaad and R. Linsker, "A Fully Pipelined FPGA Architecture of a Factored Restricted Boltzmann Machine Artificial Neural Network", *ACM Transactions on Reconfigurable Technology and Systems*, vol. 7, no. 1, pp. 1-23, 2014.

[6]M. Kurek, T. Becker and W. Luk, "Parametric Optimization of Reconfigurable Designs Using Machine Learning", *Lecture Notes in Computer Science*, pp. 134-145, 2013.

[7]L. Kim, S. Asaad and R. Linsker, "A Fully Pipelined FPGA Architecture of a Factored Restricted Boltzmann Machine Artificial Neural Network", *ACM Transactions on Reconfigurable Technology and Systems*, vol. 7, no. 1, pp. 1-23, 2014.

[8]Y. Liu, J. Bi and Z. Fan, "Multi-class sentiment classification: The experimental comparisons of feature selection and machine learning algorithms", *Expert Systems with Applications*, vol. 80, pp. 323-339, 2017.

[9]E. Bortnikov, A. Libov and O. Shacham, "WMU – Central Authentication Service", *Libproxy.library.wmich.edu*, 2017. [Online]. Available: http://libproxy.library.wmich.edu/login?url=https://search.proquest.com/docview/1904493074?accountid=15099. [Accessed: 23- Oct- 2017].

[10]Z. Zhang, "Introduction to machine learning: k-nearest neighbors", *Annals of Translational Medicine*, vol. 4, no. 11, pp. 218-218, 2016.

[11]D. Kim, J. Jung, T. Nguyen, D. Kim, M. Kim, K. Kwon and J. Jeon, "An FPGA-based Parallel Hardware Architecture for Real-time Eye Detection", *JSTS:Journal of Semiconductor Technology and Science*, vol. 12, no. 2, pp. 150-161, 2012.

[12]A. Ahmadi, H. Mattausch and T. Koide, "A parallel hardware design for snake models with an fpga architecture", *NSIP 2005. Abstracts. IEEE-Eurasip Nonlinear Signal and Image Processing, 2005.*, p. 13, 2005.

[13]J. Ratsaby and D. Zavielov, "An FPGA-based pattern classifier using data compression", *2010 IEEE 26-th Convention of Electrical and Electronics Engineers in Israel*, 2010.